<!DOCTYPE html><html lang="zh-Hans"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><meta name="description" content="晟松的博客"><meta name="keywords" content=""><meta name="author" content="晟松"><meta name="copyright" content="晟松"><title>hunnu | 晟松</title><link rel="shortcut icon" href="/logo.png"><link rel="stylesheet" href="/css/index.css?version=1.9.0"><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/font-awesome@latest/css/font-awesome.min.css?version=1.9.0"><meta name="format-detection" content="telephone=no"><meta http-equiv="x-dns-prefetch-control" content="on"><link rel="dns-prefetch" href="https://cdn.jsdelivr.net"><link rel="dns-prefetch" href="https://hm.baidu.com"><script>var _hmt = _hmt || [];
(function() {
  var hm = document.createElement("script");
  hm.src = "https://hm.baidu.com/hm.js?c34d81d53341febe06a155941e2df16d";
  var s = document.getElementsByTagName("script")[0]; 
  s.parentNode.insertBefore(hm, s);
})();</script><meta http-equiv="Cache-Control" content="no-transform"><meta http-equiv="Cache-Control" content="no-siteapp"><script>var GLOBAL_CONFIG = { 
  root: '/',
  algolia: undefined,
  localSearch: {"path":"search.xml","languages":{"hits_empty":"找不到您查询的内容:${query}"}},
  copy: {
    success: '复制成功',
    error: '复制错误',
    noSupport: '浏览器不支持'
  },
  hexoVersion: '5.4.0'
} </script><meta name="generator" content="Hexo 5.4.0"></head><body><i class="fa fa-arrow-right" id="toggle-sidebar" aria-hidden="true"></i><div id="sidebar" data-display="false"><div class="author-info"><div class="author-info__avatar text-center"><img src="/img/avatar.png"></div><div class="author-info__name text-center">晟松</div><div class="author-info__description text-center">晟松的博客</div><div class="follow-button"><a target="_blank" rel="noopener" href="https://gitee.com/cheng_song">Gitee</a></div><hr><div class="author-info-articles"><a class="author-info-articles__archives article-meta" href="/archives"><span class="pull-left">文章</span><span class="pull-right">52</span></a><a class="author-info-articles__tags article-meta" href="/tags"><span class="pull-left">标签</span><span class="pull-right">45</span></a></div></div></div><nav id="nav" style="background-image: url(/img/blog-bg.jpg)"><div id="page-header"><span class="pull-left"> <a id="site-name" href="/">晟松</a></span><i class="fa fa-bars toggle-menu pull-right" aria-hidden="true"></i><span class="pull-right menus">   <a class="site-page" href="/">Home</a><a class="site-page" href="/archives">Archives</a><a class="site-page" href="/tags">Tags</a><a class="site-page" href="/categories">Categories</a></span><span class="pull-right"><a class="site-page social-icon search"><i class="fa fa-search"></i><span> 搜索</span></a></span></div><div id="site-info"><div id="site-title">晟松</div><div id="site-sub-title">hunnu</div><div id="site-social-icons"><a class="social-icon" href="https://github.com/chengsong-hunnu" target="_blank" rel="noreferrer noopener nofollow"><i class="fa-github fa"></i></a></div></div></nav><div id="content-outer"><div class="layout" id="content-inner"><div class="recent-post-item article-container"><a class="article-title" href="/2023/03/15/vue-contentEditable-%E4%B8%8E-selection-range/">vue contentEditable 与 selection&amp;range</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2023-03-15</time><div class="content">需求类似一个公式编辑器，然后在这里面可以选择一些变量和一些运行符号，同时也可以自己输入这些符号与数字，最终进行展示。

先分析一下这个需要那些注意的点

可以点击左侧变量，自动加入右侧编辑框，同时显示的样式需要变化
运算符号同理
可以自己输入数字0-9和+ - * / ( ) 符号
其他的不准输入
 ...</div><a class="more" href="/2023/03/15/vue-contentEditable-%E4%B8%8E-selection-range/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2023/03/15/vue-iframe%E9%87%8D%E5%8A%A0%E8%BD%BD%E9%97%AE%E9%A2%98%E8%A7%A3%E5%86%B3/">vue iframe重加载问题解决</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2023-03-15</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/iframe/">iframe</a></span><div class="content">问题描述此问题为对v22 vue3系统的问题。
主要为，v22系统中存在页签这一种东西，而一个页签之中可能存在着一些地图之类的iframe界面。而在vue中，我们一般使用keep-alive与vouter-view来保持一个页面的状态，让其可以切换后不进行重走生命周期。
但是，对于iframe界面来 ...</div><a class="more" href="/2023/03/15/vue-iframe%E9%87%8D%E5%8A%A0%E8%BD%BD%E9%97%AE%E9%A2%98%E8%A7%A3%E5%86%B3/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/12/10/js%E5%B8%B8%E7%94%A8%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/">js常用设计模式</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-12-10</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/js/">js</a></span><div class="content">主要是对《JavaScript设计模式与开发实践》此书中的部分学习与记录
主要记录其中个人觉得比较重要与可能会用上的那一些设计模式类的代码思路和如何理解
单例模式全局唯一对象实例进行使用，例如window这种，需要注意的是，这个对象只能被实例化一次，之后就再也不能实例化
常见即为通过两个逻辑，一个用 ...</div><a class="more" href="/2022/12/10/js%E5%B8%B8%E7%94%A8%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/08/20/test/">无题</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-08-20</time><div class="content">说明：
本组件主要使用于三级树结构时，会对其中第二层级与第三层级的树节点进行选择时进行使用。常见表现场景即为省市区三级结构，会分别选择其中的市级与区级，此种情况下可使用此组件。常配合a-modal进行使用
直观视觉效果：
常规使用：

已存在被选择节点使用：

使用示例：
&lt;a-modal   ...</div><a class="more" href="/2022/08/20/test/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/07/23/git%E4%B8%8D%E5%B8%B8%E8%A7%81%E6%93%8D%E4%BD%9C%E7%86%9F%E6%82%89/">git不常见操作熟悉</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-07-23</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/git/">git</a></span><div class="content">git不常见操作对我来说，git的常见操作只有 clone、pull、add、log、status、commit、push这一些很常见的操作，同时还没有附带这些命令中的特殊参数，如 git log -p查看提交中的文件被修改的行，所以简要记录一下。
说明：本文根据此篇git文章进行学习，2.5 检出 ...</div><a class="more" href="/2022/07/23/git%E4%B8%8D%E5%B8%B8%E8%A7%81%E6%93%8D%E4%BD%9C%E7%86%9F%E6%82%89/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/07/16/%E9%A1%B9%E7%9B%AE%E5%BC%95%E5%85%A5%E7%81%B5%E7%8F%91%E4%BC%98%E5%8C%96/">项目引入灵珑优化</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-07-16</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/vue/">vue</a></span><div class="content">项目引入灵珑优化在一些场景中，可能会出现本项目全部由灵珑页面所构成，也可能出现其中大部分的界面可由灵珑构成，在传统的灵珑页面使用方式中，其在需要多次引入灵珑时，先创建对应的路由文件，再多次创建相似度极高的页面目录，其中大部分都只会是pageId不同，小部分可能会出现展示的renderView不同，典 ...</div><a class="more" href="/2022/07/16/%E9%A1%B9%E7%9B%AE%E5%BC%95%E5%85%A5%E7%81%B5%E7%8F%91%E4%BC%98%E5%8C%96/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/03/03/vite%E5%88%9D%E5%AD%A6%E4%B9%A0/">vite初学习</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-03-03</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/vue-vite/">vue vite</a></span><div class="content">官网
在这之前的话是有一个简单的对webpack的简单理论了解，但是因为文档或者其他的东西，对webpack的学习一直是比较缺乏的，然后现在突然想学习一下vite这个最近相对较火的东西，了解一下
它主要由两部分组成：

一个开发服务器，它基于 原生 ES 模块 提供了 丰富的内建功能，如速度快到惊人 ...</div><a class="more" href="/2022/03/03/vite%E5%88%9D%E5%AD%A6%E4%B9%A0/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2022/03/03/vue-loader%E7%AE%80%E5%8D%95%E5%AD%A6%E4%B9%A0/">vue-loader简单学习</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2022-03-03</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/vue-loader/">vue loader</a></span><div class="content">vue-loader官方介绍：起步 | Vue Loader (vuejs.org)
基本都是按照这个网站的介绍目录，一步一步的看下来，熟悉一下
因为之前有一些关于webpack的理论知识了解了，所以可以简单的理解这里面的代码和思想之类的
简要介绍一下vue-loader就是一个webpack的lo ...</div><a class="more" href="/2022/03/03/vue-loader%E7%AE%80%E5%8D%95%E5%AD%A6%E4%B9%A0/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2021/11/19/umijs+dva%E7%AE%80%E5%8D%95%E5%AD%A6%E4%B9%A0/">umijs+dva</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2021-11-19</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/umijs-dva-react/">umijs dva react</a></span><div class="content">umijs+dva虽然react这块常见的框架我似乎也只知道nextjs这一个框架（我实习这公司是配合mobx响应数据流进行开发的），然后也简单的看了了下文档，但总感觉有点不太符合习惯。可能如果是为了ssr的话，选择这个没问题。
那个时候也看了下react-router，redux这些东西，路由这个 ...</div><a class="more" href="/2021/11/19/umijs+dva%E7%AE%80%E5%8D%95%E5%AD%A6%E4%B9%A0/#more" style="margin-top: 14px">阅读更多</a><hr></div><div class="recent-post-item article-container"><a class="article-title" href="/2021/11/19/react%E5%AD%A6%E4%B9%A0%E8%AE%B0%E5%BD%95/">react简单学习记录</a><time class="post-meta__date"><i class="fa fa-calendar" aria-hidden="true"></i> 2021-11-19</time><span class="article-meta tags"><span class="article-meta__separator">|</span><i class="fa fa-tag article-meta__icon" aria-hidden="true"></i><a class="article-meta__tags" href="/tags/react-redux-hook/">react redux hook</a></span><div class="content">react简单学习记录隔了挺久再次开始写博客了，距上一篇大概差不多3个月了吧。这里面大概半个月准备考试，后面两个月在实习，然后再这个实习里面学一点新东西，就这样。虽然实际的写这个react还是在这一周左右，简单的写一下这一周写了几天代码后的感觉和知识点吧
react官方中文文档
一个入门的示例代码
 ...</div><a class="more" href="/2021/11/19/react%E5%AD%A6%E4%B9%A0%E8%AE%B0%E5%BD%95/#more" style="margin-top: 14px">阅读更多</a><hr></div><nav id="pagination"><div class="pagination"><span class="page-number current">1</span><a class="page-number" href="/page/2/">2</a><span class="space">&hellip;</span><a class="page-number" href="/page/6/">6</a><a class="extend next" rel="next" href="/page/2/"><i class="fa fa-chevron-right"></i></a></div></nav></div></div><footer class="footer-bg" style="background-image: url(/img/blog-bg.jpg)"><div class="layout" id="footer"><div class="copyright">&copy;2020 - 2023 By 晟松</div><div class="framework-info"><span>驱动 - </span><a target="_blank" rel="noopener" href="http://hexo.io"><span>Hexo</span></a><span class="footer-separator">|</span><span>主题 - </span><a target="_blank" rel="noopener" href="https://github.com/Molunerfinn/hexo-theme-melody"><span>Melody</span></a></div><div class="icp"><a target="_blank" rel="noopener" href="http://www.beian.miit.gov.cn/"><span>湘ICP备2020021729号</span></a></div><div class="busuanzi"><script async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script><span id="busuanzi_container_site_uv"><i class="fa fa-user"></i><span id="busuanzi_value_site_uv"></span><span></span></span><span class="footer-separator">|</span><span id="busuanzi_container_site_pv"><i class="fa fa-eye"></i><span id="busuanzi_value_site_pv"></span><span></span></span></div></div></footer><i class="fa fa-arrow-up" id="go-up" aria-hidden="true"></i><script src="https://cdn.jsdelivr.net/npm/animejs@latest/anime.min.js"></script><script src="https://cdn.jsdelivr.net/npm/jquery@latest/dist/jquery.min.js"></script><script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.js"></script><script src="https://cdn.jsdelivr.net/npm/velocity-animate@latest/velocity.min.js"></script><script src="https://cdn.jsdelivr.net/npm/velocity-ui-pack@latest/velocity.ui.min.js"></script><script src="/js/utils.js?version=1.9.0"></script><script src="/js/fancybox.js?version=1.9.0"></script><script src="/js/sidebar.js?version=1.9.0"></script><script src="/js/copy.js?version=1.9.0"></script><script src="/js/fireworks.js?version=1.9.0"></script><script src="/js/transition.js?version=1.9.0"></script><script src="/js/scroll.js?version=1.9.0"></script><script src="/js/head.js?version=1.9.0"></script><script src="/js/search/local-search.js"></script><script>if(/Android|webOS|iPhone|iPod|iPad|BlackBerry/i.test(navigator.userAgent)) {
  $('#nav').addClass('is-mobile')
  $('footer').addClass('is-mobile')
  $('#top-container').addClass('is-mobile')
}</script><div class="search-dialog" id="local-search"><div class="search-dialog__title" id="local-search-title">本地搜索</div><div id="local-input-panel"><div id="local-search-input"><div class="local-search-box"><input class="local-search-box--input" placeholder="搜索文章"></div></div></div><hr><div id="local-search-results"><div id="local-hits"></div><div id="local-stats"><div class="local-search-stats__hr" id="hr"><span>由</span> <a target="_blank" rel="noopener" href="https://github.com/wzpan/hexo-generator-search" style="color:#49B1F5;">hexo-generator-search</a>
 <span>提供支持</span></div></div></div><span class="search-close-button"><i class="fa fa-times"></i></span></div><div class="search-mask"></div></body></html>